#include <iostream>
#include <queue>
#include <map>
#include <unordered_map>
#include <vector>
#include <algorithm>
#include <cmath>
#include <string>
#include <cstring>
#include <set>
#include <unordered_set>
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef pair<int,int> pii;
const int N=1510, mod=1e9+7;
int a[N];
int b[N];
int f[N][N];
int main()
{
	int n,k;
	int m=0;
	cin>>n>>k;
	int idx=0;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
		if(a[i]==1)
		{
			b[++idx]=i;
			m++;
		}
	}
	f[0][0]=1;

	for(int i=1;i<=n;i++)
	{
		for(int j=min(m,i)-1;j>=0;j--)
		{
			int d=abs(b[j+1]-i);
			for(int x=0;x<=k-d;x++)
			{
				f[j+1][x+d]=(f[j+1][x+d]+f[j][x])%mod;
			}
			
		}
	}
	ll ans=0;
	for(int i=k;i>=0;i-=2)
	{
		ans=(ans+f[m][i])%mod;
	}
	cout<<ans;

	return 0;
}

